import { Message, MessageBox } from 'element-ui'
import util from '@/libs/util.js'
import router from '@/router'
import { AccountLogin } from '@api/sys.login'

export default {
    namespaced: true,
    actions: {
        /**
         * @description 登录
         * @param {Object} context
         * @param {Object} payload username {String} 用户账号
         * @param {Object} payload password {String} 密码
         * @param {Object} payload route {Object} 登录成功后定向的路由对象 任何 vue-router 支持的格式
         */
        login({ dispatch }, {
            username = '',
            password = ''
        } = {}) {
            return new Promise((resolve, reject) => {
                // 开始请求登录接口
                AccountLogin({
                        username,
                        password
                    })
                    .then(async res => {
                        // 设置 cookie 一定要存 id 和 token 两个 cookie
                        // 整个系统依赖这两个数据进行校验和存储
                        // id 是用户身份唯一标识 用户注册的时候确定 并且不可改变 不可重复
                        // token 代表用户当前登录状态 建议在网络请求中携带 token
                        // 如有必要 token 需要定时更新，默认保存一天
                        console.log(res)
                        util.cookies.set('id', res.userId)
                        util.cookies.set('tokenHead', res.tokenHead)
                        util.cookies.set('token', res.token)

                        // 登录成功后，加载用户信息和权限信息
                        var userInfo = { id: res.userId, name: res.userName }
                        sessionStorage.setItem('userInfo', JSON.stringify(userInfo))

                        // userInfo({ id: res.userId, token: res.token }).then(res => {
                        //   console.log('get user info:  ', res)
                        //   if (res.status === 401) {
                        //     console.log('加载用户信息失败')
                        //   } else {
                        //     let userInfo = res.data
                        //     sessionStorage.setItem('userInfo', JSON.stringify(userInfo))
                        //   }
                        // })
                        // 设置 vuex 用户信息
                        await dispatch('d2admin/user/set', {
                                name: res.userName,
                                id: res.userId
                            }, { root: true })
                            // 用户登录后从持久化数据加载一系列的设置
                        await dispatch('load')
                            // 结束
                        resolve()
                    })
                    .catch(err => {
                        Message.error('登录失败')
                    })
            })
        },
        /**
         * @description 注销用户并返回登录页面
         * @param {Object} context
         * @param {Object} payload confirm {Boolean} 是否需要确认
         */
        logout({ commit, dispatch }, { confirm = false } = {}) {
            /**
             * @description 注销
             */
            async function logout() {
                // 删除cookie
                util.cookies.remove('token')
                util.cookies.remove('id')
                    // 退出后将sessionStorage中的用户信息删除
                sessionStorage.removeItem('userInfo')
                    // 清空 vuex 用户信息
                await dispatch('d2admin/user/set', {}, { root: true })
                    // 跳转路由
                router.push({
                    name: 'login'
                })
            }
            // 判断是否需要确认
            if (confirm) {
                commit('d2admin/gray/set', true, { root: true })
                MessageBox.confirm('确定要注销当前用户吗', '注销用户', {
                        type: 'warning'
                    })
                    .then(() => {
                        commit('d2admin/gray/set', false, { root: true })
                        logout()
                    })
                    .catch(() => {
                        commit('d2admin/gray/set', false, { root: true })
                        Message({
                            message: '取消注销操作'
                        })
                    })
            } else {
                logout()
            }
        },
        /**
         * @description 用户登录后从持久化数据加载一系列的设置
         * @param {Object} context
         */
        load({ dispatch }) {
            return new Promise(async resolve => {
                // DB -> store 加载用户名
                await dispatch('d2admin/user/load', null, { root: true })
                    // DB -> store 加载主题
                await dispatch('d2admin/theme/load', null, { root: true })
                    // DB -> store 加载页面过渡效果设置
                await dispatch('d2admin/transition/load', null, { root: true })
                    // DB -> store 持久化数据加载上次退出时的多页列表
                await dispatch('d2admin/page/openedLoad', null, { root: true })
                    // DB -> store 持久化数据加载侧边栏折叠状态
                await dispatch('d2admin/menu/asideCollapseLoad', null, { root: true })
                    // DB -> store 持久化数据加载全局尺寸
                await dispatch('d2admin/size/load', null, { root: true })
                    // DB -> store 持久化数据加载颜色设置
                await dispatch('d2admin/color/load', null, { root: true })
                    // end
                resolve()
            })
        }
    }
}